草庐IT

java - 检查 JPQL 查询中集合的 NULL?

全部标签

sql - 使用 SQL IN 和 SQL OR 运算符的 Rails 3 ActiveRecord 查询

我正在使用“where”语法编写一个Rails3ActiveRecord查询,它同时使用了SQLIN和SQLOR运算符,但不知道如何同时使用它们。此代码有效(在我的用户模型中):Question.where(:user_id=>self.friends.ids)#note:self.friends.idsreturnsanarrayofintegers但是这段代码Question.where(:user_id=>self.friends.idsOR:target=>self.friends.usernames)返回这个错误syntaxerror,unexpectedtCONSTANT,

ruby - 在连接之前检查 nil 字符串

这个问题类似于很多问题,但绝不是重复的。这个问题是关于字符串连接和编写比检查零/零更好的代码。目前我有:file.puts"cn:"+(var1.nil??"UNKNOWN":var1)效果很好,但看起来不太好。有什么更好的方法可以用ruby​​编写它,以便我检查nil而不是连接它 最佳答案 你可以这样做:file.puts"cn:"+(var1||"UNKNOWN")或者,如果您愿意,也可以:file.puts"cn:"+(var1or"UNKNOWN")或者我最喜欢的,我认为是最地道的ruby​​:file.puts"cn:#{

ruby - 如何检查一个范围是否包含另一个范围的子集?

如果我有两个重叠的范围:x=1..10y=5..15当我说:putsx.include?y输出是:false因为这两个范围只是部分重叠。但是如果我希望它在两个范围之间有部分重叠时为“真”,我该如何写呢?换句话说,我需要一种方法来知道一个范围何时包含另一个范围的子集。我认为有一种优雅的方式可以用Ruby编写它,但我能想到的唯一解决方案是冗长的。 最佳答案 有效的方法是比较极限(x.first 关于ruby-如何检查一个范围是否包含另一个范围的子集?,我们在StackOverflow上找到一

ruby-on-rails - 如何修复 Rails 中 pg_attribute 表的缓慢隐式查询

在我们的生产环境中,我们注意到Rails应用程序频繁出现峰值(大约每1小时一次)。深入挖掘,这是由于以下查询在单个HTTP请求中累计运行时间超过1.5秒(称为100倍)。SELECTa.attname,format_type(a.atttypid,a.atttypmod),pg_get_expr(d.adbin,d.adrelid),a.attnotnull,a.atttypid,a.atttypmodFROMpg_attributeaLEFTJOINpg_attrdefdONa.attrelid=d.adrelidANDa.attnum=d.adnumWHEREa.attrelid=

ruby - 自动记录 DataMapper 查询

我正在使用DataMapper在Sinatra中开发一个简单的应用程序。我想查看DM为我的各种链式查找器等创建的查询。我试过:DataMapper::Logger.new(STDOUT,:debug)在我的configuredo...endblock中,environment.rb文件会在应用程序启动时加载。我也试过:DataMapper::Logger.new('log/my-app.log',:debug)既不会从通过浏览器或通过需要我的应用程序的irbsession访问的应用程序生成日志语句。我确实看到了应用启动消息。我正在使用rackupconfig.ru在本地运行应用程序。我

ruby-on-rails - 检查 ActiveRecord 查找是否返回结果

我正在尝试检查查找方法是否返回结果。我的查找方法如下:post=Post.find(:all,:conditions=>{:url=>params['url']},:limit=>1)检查post是否包含结果的好方法是什么? 最佳答案 find:all如果没有返回任何行,则返回一个空数组([]),因此您可以这样使用它:post=Post.find(:all,:conditions=>{:url=>params['url']},:limit=>1)unlesspost.empty?#dosomething...end顺便说一句,如果您

ruby - 检查模块是否存在于 ruby​​ 中

我根据cli上传递的参数动态定义模块名称,例如Required::Module::#{ARGV.first}有什么方法可以检查该模块是否存在?另外,我如何在不知道它的确切名称的情况下对其运行方法? 最佳答案 为此使用const_defined?。Required::Module.const_defined?(:ModuleName)返回真或假。 关于ruby-检查模块是否存在于ruby​​中,我们在StackOverflow上找到一个类似的问题: https:

ruby-on-rails - 处理用户发送的 "string contains null byte"

我有一个APIController,它使用PostgreSQL/Rails接收有关媒体文件路径和id3标签的信息,并将它们保存到ActiveRecord实例。有时用户会发送如下字符串:"genre"=>"Hip-Hop\u0000Hip-Hop/Rap"当试图坚持save时,Rails/Postgres对此并不十分满意:AnArgumentErroroccurredininternals#receive:stringcontainsnullbyteactiverecord(3.2.21)lib/active_record/connection_adapters/postgresql_a

ruby-on-rails - 将查询字符串附加到 url

我有一个回调url字符串params[:callback],我需要附加一个查询字符串"&result=true"并重定向用户。我发现这样做的更好方法是使用addressable但我认为代码对于这样的任务来说太大了,尤其是当我们谈论ruby​​时:callback=Addressable::URI.parse(params[:callback])query=callback.query_valuesquery[:result]='true'callback.query_values=queryredirect_tocallback.to_s是否有更优雅的方式来获得与此代码段相同的结果?

ruby-on-rails - 如何检查将脚本/运行程序作为 shebang 的 ruby​​ 脚本的语法?

我在检查其shebang上有railsscript/runner的ruby​​脚本的语法时遇到问题。这里有两个示例脚本以及它们如何响应ruby​​语法检查:脚本hello_world_runner.rb:#!/usr/bin/envscript/runnerp"Helloworld!"脚本hello_world.rb#!/usr/bin/envrubyp"Helloworld!"这是我尝试检查语法的方法。第一行是命令,第二行是输出。$ruby-chello_world_runner.rb"Helloworld!"$ruby-chello_world.rbSYNTAXOK